import Vue from 'vue'

import 'normalize.css/normalize.css' // A modern alternative to CSS resets

import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
// import locale from 'element-ui/lib/locale/lang/en' // 多语言也叫做国际化

import '@/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'

import '@/icons' // icon
import '@/permission' // permission control

// 封装一个按钮权限动态判断的自定义指令
// v-auth怎么实现的
Vue.directive('permission', {
  inserted(el, binding) {
    // console.log(el) // dom元素
    // console.log(binding.value) // 传递过来的值 add-emp 当前按钮的操作表示
    // 判断当前用户可操作的按钮标识里面是否有当前按钮的标识
    if (!store.state.user.userInfo.roles.points.includes(binding.value)) {
      el.remove() // 把当前dom节点移除掉
    }
  }
})

Vue.use(ElementUI)
Vue.config.productionTip = false

// 整个项目的启动
new Vue({
  el: '#app', // 指定挂载的节点，css的选择器
  router, // 路由配置
  store, // store仓库
  render: h => h(App) // 此处渲染了根组件
})

// 项目介绍，需要写到简历里面的，面试的时候需要讲出来。
// 项目大概多少模块，多少页面
// 你自己负责多少页面
// 项目的排期，多长时间写完的
// 自研项目还是外包项目
// 难点

// 人资项目也可以，但是业务比较单一，跟业务不相关。
// 最好跟业务相关的项目。
// 5-6个模块的介绍，这个模块的名字，有哪些功能，封装了哪些组件。

